package com.yidi.system.domain;

import com.fasterxml.jackson.annotation.JsonFormat;
import com.yidi.common.annotation.Excel;
import com.yidi.common.core.domain.BaseEntity;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Table;
import javax.persistence.Transient;
import java.util.Date;

/**
 * @author ：Xn
 * @ClassName: SysOperLog
 * @date ：2021-10-19 16:31
 * @describe ：操作日志记录表
 */
@Getter
@Setter
@Entity
@Table(name = "sys_oper_log")
@ToString(callSuper=true)
public class SysOperLog extends BaseEntity
{
    private static final long serialVersionUID = 1L;

    /** 操作模块 */
    @Excel(name = "操作模块")
    private String title;

    /** 业务类型（0其它 1新增 2修改 3删除） */
    @Excel(name = "业务类型", readConverterExp = "0=其它,1=新增,2=修改,3=删除,4=授权,5=导出,6=导入,7=强退,8=生成代码,9=清空数据")
    @Column(name = "business_type")
    private Integer businessType;

    /** 业务类型数组 */
    @Transient //不在数据库中做映射
    private Integer[] businessTypes;

    /** 请求方法 */
    @Excel(name = "请求方法")
    private String method;

    /** 请求方式 */
    @Excel(name = "请求方式")
    @Column(name = "request_method")
    private String requestMethod;

    /** 操作类别（0其它 1后台用户 2手机端用户） */
    @Excel(name = "操作类别", readConverterExp = "0=其它,1=后台用户,2=手机端用户")
    @Column(name = "operator_type")
    private Integer operatorType;

    /** 操作人员 */
    @Excel(name = "操作人员")
    @Column(name = "oper_name")
    private String operName;

    /** 部门名称 */
    @Excel(name = "部门名称")
    @Column(name = "dept_name")
    private String deptName;

    /** 请求url */
    @Excel(name = "请求地址")
    @Column(name = "oper_url")
    private String operUrl;

    /** 操作地址 */
    @Excel(name = "操作地址")
    @Column(name = "oper_ip")
    private String operIp;

    /** 操作地点 */
    @Excel(name = "操作地点")
    @Column(name = "oper_location")
    private String operLocation;

    /** 请求参数 */
    @Excel(name = "请求参数")
    @Column(name = "oper_param",columnDefinition = "longtext", nullable = true)
    private String operParam;

    /** 返回参数 */
    @Excel(name = "返回参数")
    @Column(name = "json_result")
    private String jsonResult;

    /** 操作状态（0正常 1异常） */
    @Excel(name = "状态", readConverterExp = "0=正常,1=异常")
    private Integer status;

    /** 错误消息 */
    @Excel(name = "错误消息")
    @Column(name = "error_msg")
    private String errorMsg;

    /** 操作时间 */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "操作时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    @Column(name = "oper_time")
    private Date operTime;

}
